<?php
/**
 +---------------------------------<br/>
 * 功能:处理字符串的工具类<br/>
 +---------------------------------
 * @category betterlife
 * @package util.common
 * @author skygreen
 */
class UtilString extends Util 
{
	/**
	 * 查看字符串里是否包含指定字符串
	 * @param mixed $subject
	 * @param mixed $needle
	 */
	public static function contain($subject,$needle) 
	{
		if (strpos($subject,$needle)!== false) {
			return true;
		}else {
			return false;
		}
	}
	
	/**
	 * 检查是否有影响系统稳定，数据完全的字符。 
	 * @param type $str 字符串
	 * @return bool 是否有影响系统稳定，数据完全的字符。 
	 */
	public static function has_unsafeword($str)
	{
		return preg_match('/~!@#\\$%\\^&\\*\\(\\)\\+=\\|\\}]{\\[":><\\?;\'\/\\.,/', $str);
	}

	/**
	 * 查看字符串是否包含中文 
	 * @param string $string 查看的字符串 
	 * @return bool 是否包含中文
	 */
	public static function is_chinese($string)
	{
		return preg_match("/[\x80-\xff]./", $string);
	}
	
	/**
	 * 返回中文文字内容的长度。
	 * @param string $title 中文文字内容
	 * @return int 中文文字内容的长度
	 */
	public static function strlenChinaese( $title )
	{
		$realnum = 0;
		for($i=0;$i<strlen($title);$i++)
		{
			$ctype = 0;
			$cstep = 0;

			$cur = substr($title,$i,1);
			if($cur == "&")
			{
				if(substr($title,$i,4) == "&lt;")
				{
					$i += 3;
					$realnum ++;
				}
				else if(substr($title,$i,4) == "&gt;")
				{
					$i += 3;
					$realnum ++;
				}
				else if(substr($title,$i,5) == "&amp;")
				{
					$i += 4;
					$realnum ++;
				}
				else if(substr($title,$i,6) == "&quot;")
				{
					$i += 5;
					$realnum ++;
				}
				else if(preg_match("/&#(\d+);?/i",substr($title,$i,8),$match))
				{
					$i += strlen($match[0])-1;
					$realnum ++;
				}
			}else
			{
				if(ord($cur)>=252)
				{
					$i += 5;
					$realnum ++;
					if($magic)
					{
						$blen ++;
						$ctype = 1;
					}
				}
				else if(ord($cur)>=248)
				{
					$i += 4;
					$realnum ++;
				}
				else if(ord($cur)>=240)
				{
					$i += 3;
					$realnum ++;
				}
				else if(ord($cur)>=224)
				{
					$i += 2;
					$realnum ++;
				}
				else if(ord($cur)>=192)
				{
					$i += 1;
					$realnum ++;
				}
				else
				{
					$realnum ++;
				}
			}
		}
		return $realnum;
	}
	
	/**
	 +----------------------------------------------------------<br/>
	 * 检查字符串是否是UTF8编码<br/>
	 +----------------------------------------------------------
	 * @param string $string 字符串
	 +----------------------------------------------------------
	 * @return Boolean
	 +----------------------------------------------------------
	 */
	public static function is_utf8($str) 
	{
		if (function_exists('mb_check_encoding')){
			if (mb_check_encoding($str,'UTF-8')){  
				return true;    
			}else{
				return false;
			}        
		}else{
			$c=0;
			$b=0;
			$bits=0;
			$len=strlen($str);
			for($i=0; $i<$len; $i++) {
				$c=ord($str[$i]);
				if($c > 128) {
					if(($c >= 254)) return false;
					elseif($c >= 252) $bits=6;
					elseif($c >= 248) $bits=5;
					elseif($c >= 240) $bits=4;
					elseif($c >= 224) $bits=3;
					elseif($c >= 192) $bits=2;
					else return false;
					if(($i+$bits) > $len) return false;
					while($bits > 1) {
						$i++;
						$b=ord($str[$i]);
						if($b < 128 || $b > 191) return false;
						$bits--;
					}
				}
			}
			return true;
		}
	}

	/**
	 * 定义字符转换函数，解决mssql中文乱码问题
	 */
	public static function gbk2utf8($string) 
	{
		return iconv("gbk","utf-8",$string);
	}

	/**
	 * 将UTF8编码的字符串转换成GBK编码的字符串
	 * @param string $string 原字符串
	 * @return string 转换后的字符串
	 */
	public static function utf82gbk($string) 
	{
		return iconv("utf-8","gbk",$string);
	}  
	 
	/**
	 * 在线模式:移除js,css里所有的换行，注释和冗余的空格
	 */
	public static function online_optimize($result)
	{                             
		$result=preg_replace("/(\/\/[\s\S]*?([\r]|[\n]))/", "",$result); //去掉js行注释如://   
		$result=preg_replace("/(\/\*[\s\S]*?\*\/|[\r]|[\n]|[\r\n])/", "",$result);//去掉css注释如:/*   */        
		$result=str_replace(array("\r\n","	","    ","\r", "\n", "\t"),"",$result);                      
		/** 移除无需的空格 */        
		$result = str_replace('{ ', '{', $result);
		$result = str_replace(' }', '}', $result);
		$result = str_replace('; ', ';', $result);
		$result = str_replace(', ', ',', $result);
		$result = str_replace(' {', '{', $result);
		$result = str_replace('} ', '}', $result);
		$result = str_replace(': ', ':', $result);    
		$result = str_replace(' :', ':', $result);
		$result = str_replace(' ,', ',', $result);
		$result = str_replace(' ;', ';', $result);
		return $result;
	}
				
	/**
	 * 截取指定的字符串到指定长度。
	 * 1.英文按单词截取指定长度数的单词。
	 * 2.中文按单字截取指定长度数的字。 
	 * @param $string the original string
	 * @param $count  the word count
	 * @param $ellipsis  TRUE to add "..." or use a string to define other character   
	 * @param $count  the word count        
	 * @return
	 * trimmed string with ellipsis added if it was truncated
	 */
	public static function word_trim($string,$count,$ellipsis = true,$isChinese=true)
	{    
		if ($isChinese){
			$string = UtilString::msubstr($string,0,$count);  
			if (is_string($ellipsis)){
				$string.=$ellipsis;
			}
			elseif ($ellipsis){
				$string .= '&hellip;' ;
			}                        
			return $string;  
		}else{
			$words = preg_split("/[\s]+/",$string);
			if (count($words)>$count){
				array_splice($words,$count);
				$string=implode(" ",$words);
				if (is_string($ellipsis)){
					$string.=$ellipsis;
				}
				elseif ($ellipsis){
					$string .= '&hellip;' ;
				}
			}
			return $string ;    
		}
	}

	/**
	 +----------------------------------------------------------<br/>
	 * 字符串截取，支持中文和其他编码<br/>
	 +----------------------------------------------------------
	 * @static
	 * @access public
	 +----------------------------------------------------------
	 * @param string $str 需要转换的字符串
	 * @param string $start 开始位置
	 * @param string $length 截取长度
	 * @param string $charset 编码格式
	 * @param string $suffix 截断显示字符
	 +----------------------------------------------------------
	 * @return string
	 +----------------------------------------------------------
	 */
	public static function msubstr($str, $start=0, $length=0, $charset="utf-8", $suffix=true) 
	{
		if(function_exists("mb_substr"))
			return mb_substr($str, $start, $length, $charset);
		elseif(function_exists('iconv_substr')) {
			return iconv_substr($str,$start,$length,$charset);
		}
		$re['utf-8']   = "/[\x01-\x7f]|[\xc2-\xdf][\x80-\xbf]|[\xe0-\xef][\x80-\xbf]{2}|[\xf0-\xff][\x80-\xbf]{3}/";
		$re['gb2312'] = "/[\x01-\x7f]|[\xb0-\xf7][\xa0-\xfe]/";
		$re['gbk']      = "/[\x01-\x7f]|[\x81-\xfe][\x40-\xfe]/";
		$re['big5']      = "/[\x01-\x7f]|[\x81-\xfe]([\x40-\x7e]|\xa1-\xfe])/";
		preg_match_all($re[$charset], $str, $match);
		$slice = join("",array_slice($match[0], $start, $length));
		if($suffix) return $slice."…";
		return $slice;
	}

	/**
	 +----------------------------------------------------------<br/>
	 * 产生随机字串，可用来自动生成密码<br/>
	 * 默认长度6位 字母和数字混合 支持中文<br/>
	 +----------------------------------------------------------
	 * @param string $len 长度
	 * @param string $type 字串类型
	 * 0 字母 1 数字 2 大写字母 3 小写字母 4 中文 5 百家姓 其它 混合 
	 * @param string $addChars 额外字符
	 +----------------------------------------------------------
	 * @return string
	 +----------------------------------------------------------
	 */
	public static function rand_string($len=6,$type='',$addChars='') 
	{
		$str ='';
		switch($type) {
			case 0:
				$chars='ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'.$addChars;
				break;
			case 1:
				$chars= str_repeat('0123456789',3);
				break;
			case 2:
				$chars='ABCDEFGHIJKLMNOPQRSTUVWXYZ'.$addChars;
				break;
			case 3:
				$chars='abcdefghijklmnopqrstuvwxyz'.$addChars;
				break;
			case 4:
				$chars = "们以我到他会作时要动国产的一是工就年阶义发成部民可出能方进在了不和有大这主中人上为来分生对于学下级地个用同行面说种过命度革而多子后自社加小机也经力线本电高量长党得实家定深法表着水理化争现所二起政三好十战无农使性前等反体合斗路图把结第里正新开论之物从当两些还天资事队批点育重其思与间内去因件日利相由压员气业代全组数果期导平各基或月毛然如应形想制心样干都向变关问比展那它最及外没看治提五解系林者米群头意只明四道马认次文通但条较克又公孔领军流入接席位情运器并飞原油放立题质指建区验活众很教决特此常石强极土少已根共直团统式转别造切九你取西持总料连任志观调七么山程百报更见必真保热委手改管处己将修支识病象几先老光专什六型具示复安带每东增则完风回南广劳轮科北打积车计给节做务被整联步类集号列温装即毫知轴研单色坚据速防史拉世设达尔场织历花受求传口断况采精金界品判参层止边清至万确究书术状厂须离再目海交权且儿青才证低越际八试规斯近注办布门铁需走议县兵固除般引齿千胜细影济白格效置推空配刀叶率述今选养德话查差半敌始片施响收华觉备名红续均药标记难存测士身紧液派准斤角降维板许破述技消底床田势端感往神便贺村构照容非搞亚磨族火段算适讲按值美态黄易彪服早班麦削信排台声该击素张密害侯草何树肥继右属市严径螺检左页抗苏显苦英快称坏移约巴材省黑武培著河帝仅针怎植京助升王眼她抓含苗副杂普谈围食射源例致酸旧却充足短划剂宣环落首尺波承粉践府鱼随考刻靠够满夫失包住促枝局菌杆周护岩师举曲春元超负砂封换太模贫减阳扬江析亩木言球朝医校古呢稻宋听唯输滑站另卫字鼓刚写刘微略范供阿块某功套友限项余倒卷创律雨让骨远帮初皮播优占死毒圈伟季训控激找叫云互跟裂粮粒母练塞钢顶策双留误础吸阻故寸盾晚丝女散焊功株亲院冷彻弹错散商视艺灭版烈零室轻血倍缺厘泵察绝富城冲喷壤简否柱李望盘磁雄似困巩益洲脱投送奴侧润盖挥距触星松送获兴独官混纪依未突架宽冬章湿偏纹吃执阀矿寨责熟稳夺硬价努翻奇甲预职评读背协损棉侵灰虽矛厚罗泥辟告卵箱掌氧恩爱停曾溶营终纲孟钱待尽俄缩沙退陈讨奋械载胞幼哪剥迫旋征槽倒握担仍呀鲜吧卡粗介钻逐弱脚怕盐末阴丰雾冠丙街莱贝辐肠付吉渗瑞惊顿挤秒悬姆烂森糖圣凹陶词迟蚕亿矩康遵牧遭幅园腔订香肉弟屋敏恢忘编印蜂急拿扩伤飞露核缘游振操央伍域甚迅辉异序免纸夜乡久隶缸夹念兰映沟乙吗儒杀汽磷艰晶插埃燃欢铁补咱芽永瓦倾阵碳演威附牙芽永瓦斜灌欧献顺猪洋腐请透司危括脉宜笑若尾束壮暴企菜穗楚汉愈绿拖牛份染既秋遍锻玉夏疗尖殖井费州访吹荣铜沿替滚客召旱悟刺脑措贯藏敢令隙炉壳硫煤迎铸粘探临薄旬善福纵择礼愿伏残雷延烟句纯渐耕跑泽慢栽鲁赤繁境潮横掉锥希池败船假亮谓托伙哲怀割摆贡呈劲财仪沉炼麻罪祖息车穿货销齐鼠抽画饲龙库守筑房歌寒喜哥洗蚀废纳腹乎录镜妇恶脂庄擦险赞钟摇典柄辩竹谷卖乱虚桥奥伯赶垂途额壁网截野遗静谋弄挂课镇妄盛耐援扎虑键归符庆聚绕摩忙舞遇索顾胶羊湖钉仁音迹碎伸灯避泛亡答勇频皇柳哈揭甘诺概宪浓岛袭谁洪谢炮浇斑讯懂灵蛋闭孩释乳巨徒私银伊景坦累匀霉杜乐勒隔弯绩招绍胡呼痛峰零柴簧午跳居尚丁秦稍追梁折耗碱殊岗挖氏刃剧堆赫荷胸衡勤膜篇登驻案刊秧缓凸役剪川雪链渔啦脸户洛孢勃盟买杨宗焦赛旗滤硅炭股坐蒸凝竟陷枪黎救冒暗洞犯筒您宋弧爆谬涂味津臂障褐陆啊健尊豆拔莫抵桑坡缝警挑污冰柬嘴啥饭塑寄赵喊垫丹渡耳刨虎笔稀昆浪萨茶滴浅拥穴覆伦娘吨浸袖珠雌妈紫戏塔锤震岁貌洁剖牢锋疑霸闪埔猛诉刷狠忽灾闹乔唐漏闻沈熔氯荒茎男凡抢像浆旁玻亦忠唱蒙予纷捕锁尤乘乌智淡允叛畜俘摸锈扫毕璃宝芯爷鉴秘净蒋钙肩腾枯抛轨堂拌爸循诱祝励肯酒绳穷塘燥泡袋朗喂铝软渠颗惯贸粪综墙趋彼届墨碍启逆卸航衣孙龄岭骗休借".$addChars;
				break;
			case 5:
				$chars ="王张李陈刘杨吴黄周徐朱赵胡孙郑何郭沈高林谢马叶罗冯许萧汪韩曹潘吕姚程余袁宋钱陆卢唐彭蒋曾邓蔡顾魏方傅金范梁夏董章俞丁江杜邹钟苏严戴崔田毛石任龚陶邵薛丘熊侯谭姜贾施秦史廖于孔尹黎孟段汤白詹聂易洪盛倪康文";
				break;
			default :
			// 默认去掉了容易混淆的字符oOLl和数字01，要添加请使用addChars参数
				$chars='ABCDEFGHIJKMNPQRSTUVWXYZabcdefghijkmnpqrstuvwxyz23456789'.$addChars;
				break;
		}
		if($len>10 ) {//位数过长重复字符串一定次数
			$chars= $type==1? str_repeat($chars,$len) : str_repeat($chars,5);
		}
		if(($type==4)||($type==5)) {
			// 中文随机字
			for($i=0;$i<$len;$i++) {
				$str.= self::msubstr($chars, floor(mt_rand(0,mb_strlen($chars,'utf-8')-1)),1);
			}
		}else {
			$chars   =   str_shuffle($chars);
			$str     =   substr($chars,0,$len);
		}
		return $str;
	} 

	/**
	 +----------------------------------------------------------<br/>
	 * 生成一定数量的随机数，并且不重复<br/>
	 +----------------------------------------------------------
	 * @param integer $number 数量
	 * @param string $len 长度
	 * @param string $type 字串类型
	 * 0 字母 1 数字 其它 混合
	 +----------------------------------------------------------
	 * @return array
	 +----------------------------------------------------------
	 */
	public static function build_count_rand ($number,$length=4,$mode=1) 
	{
		if($mode==1 && $length<strlen($number) ) {
			//不足以生成一定数量的不重复数字
			return false;
		}
		$rand   =  array();
		for($i=0; $i<$number; $i++) {
			$rand[] = self::rand_string($length,$mode);
		}
		$unqiue = array_unique($rand);
		if(count($unqiue)==count($rand)) {
			return $rand;
		}
		$count   = count($rand)-count($unqiue);
		for($i=0; $i<$count*3; $i++) {
			$rand[] =  self::rand_string($length,$mode);
		}
		$rand = array_slice(array_unique($rand),0,$number);
		return $rand;
	}

	/**
	 +----------------------------------------------------------<br/>
	 *  带格式生成随机字符 支持批量生成<br/>
	 *  但可能存在重复<br/>
	 +----------------------------------------------------------
	 * @param string $format 字符格式
	 *     # 表示数字 * 表示字母和数字 $ 表示字母 . 小写字母
	 * @param integer $number 生成数量
	 +----------------------------------------------------------
	 * @return string | array
	 +----------------------------------------------------------
	 */
	public static function build_format_rand($format,$number=1) 
	{
		$str  =  array();
		$length =  strlen($format);
		for($j=0; $j<$number; $j++) {
			$strtemp   = '';
			for($i=0; $i<$length; $i++) {
				$char = substr($format,$i,1);
				switch($char) {
					case "*"://字母和数字混合
						$strtemp   .= self::rand_string(1);
						break;
					case "#"://数字
						$strtemp  .= self::rand_string(1,1);
						break;
					case "$"://大写字母
						$strtemp .=  self::rand_string(1,2);
						break;
                    case "."://小写字母
						$strtemp .=  self::rand_string(1,3);
                        break;
					default://其他格式均不转换
						$strtemp .=   $char;
						break;
				}
			}
			$str[] = $strtemp;
		}
		return $number==1? $strtemp : $str ;
	}
	
	/**
	* 去除Html标签   
	* str 需要截去的对象
	*/
	public static function delhtml($str){   //清除HTML标签
		$st=-1; //开始
		$et=-1; //结束
		$stmp=array();
		$stmp[]="&nbsp;";
		$len=strlen($str);
		for($i=0;$i<$len;$i++){
		   $ss=substr($str,$i,1);
		   if(ord($ss)==60){ //ord("<")==60
			$st=$i;
		   }
		   if(ord($ss)==62){ //ord(">")==62
			$et=$i;
			if($st!=-1){
			 $stmp[]=substr($str,$st,$et-$st+1);
			}
		   }
		}
		$str=str_replace($stmp,"",$str);
		return $str;
	}

	/**
	 * 将形如"-x-x-x"的字符串转为数组(需优化，可用正则处理且可将连字符作为参数传入)
	 * @param string str 需转换的字符串
	 * @return array result 字符数组
	 */
	public static function hyphenStrToArr($str)
	{
		$length   = strlen(trim($str));
		if($length>=3){
			$trimstr = substr($str,1,$length-2);
			$arr     = explode('-',$trimstr);
			return $arr;
		}else{
			return false;
		}
	}
}

//print_r(UtilString::build_format_rand("#", 16));
?>
